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DRIVE MECHANISM CONTROL DEVICE AND METHOD, DRIVING 
OPERATION CONFIRMATION METHOD FOR A DRIVE MECHANISM, 
AND PROGRAMS FOR IMPLEMENTING THE METHODS 

Inventor: Yuji Kawase 

5 

BACKGROUND OF THE INVENTION 

Field of the Invention 

The present invention relates to a drive mechanism requiring accurate and 
precise operation, to control methods for the drive mechanism, and to programs for 
10 implementing the methods. More particularly, this invention relates to a control 
device, methods and programs for driving precisely and at high speed a drive 
mechanism, such as those used in modern electronic devices, corresponding control 
methods. 

Description of the Related Art 

15 Extremely high speed, precise operation is necessary in the drive 

mechanisms for many modern electronic devices. In printers, for example, this has 
meant using stepping motors or linear motors for driving the paper transport 
mechanism and carriage mechanism. In order to print the desired text or graphic in 
the correct position, it is also necessary to drive the print head (print operation) 

20 quickly and precisely according to the movement of the carriage and print medium 
(paper). 

Conventional drive mechanism control technology includes CPU interrupt 
signal control methods and control methods using dedicated hardware. Fast, precise 
drive control of a print head drive mechanism by these conventional methods is 

25 further described below, by way of example, using drive control with a stepping 
motor (referred to as simply a "motor" below). Note that similar drive control is also 
needed for other mechanisms. The phase pattern of current applied to the motor at 
the phase change timing must be changed, and the amount of current flowing to the 
motor may also need to be changed, as part of motor drive control. Control during 

30 motor acceleration and deceleration is particularly complex because the phase 
change timing must be sequentially changed while at the same time sequentially 
changing the amount of current supplied to the motor according to the specific 
acceleration or deceleration conditions. 
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Control with dedicated hardware uses special dedicated hardware to control 
motor phase change and current supply. However, while using dedicated hardware 
offers the advantage of high precision drive control, the cost of providing such 
dedicated hardware is generally high. Other disadvantages of using dedicated 
5 hardware are longer development time and the inability to flexibly and easily 
change the control method. 

In CPU-based interrupt control methods the CPU runs an interrupt process 
at a specific timing to read from memory control data for changing the phase 
pattern of current applied to the motor or controlling the amount of current flowing 
10 to the motor, and supply this control data to a drive controller. This method makes 
it possible to shorten product development time and flexibly change the control 
operation, while also helping to minimize development and product costs. CPU 
interrupt control methods are therefore widely used in the development of modern 
electronics because of their ability to shorten development time and accommodate 
\n 15 fast changes in design requirements. 

Ilj The CPU interrupt control process can ensure precise drive control according 

to the control data sent from the CPU as long as the drive device ("driver" below) is 
3 operating. However, various errors and problem factors can prevent the driver from 

^ operating according to the drive control data. In the carriage drive mechanism of a 

II 20 print head, for example, the carriage mechanism can be prevented from moving by 
3 an obstruction, such as a paper jam, in the carriage path. Under such circumstances 

changing the phase pattern or current supply from the controller will not cause the 
motor to turn because the carriage cannot move. When this happens the expected 
carriage position (that is, the position where the carriage should be or logical 
25 operating position) computed by the controller from the control data differs from the 
position where the carriage is actually present (the "current operating position"), 
and carriage drive cannot be precisely controlled. 

An appropriate process must therefore be executed to handle such problems. 
In the print head carriage drive mechanism, for example, sensors regularly detect 
30 the actual carriage position to confirm if the carriage is being driven correctly. 
Operation is confirmed by CPU control causing the carriage to move regularly (such 
as every 6 seconds) to a specific sensor position (such as the home position) to detect 
the physical carriage position, compare this actual carriage position with the 
computed logical position, and detect any offset therebetween. 

35 This position confirmation is also accomplished by a CPU interrupt process 

reading drive control data from memory to drive the motor and move the carriage to 
the home position. Drive control accuracy is confirmed from the logical carriage 
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position computed from the control data, and the offset from the actual carriage 
position detected at the home position. 

A conventional drive operation confirmation process using a CPU is described 
below with reference to Fig. 18. CPU 1 reads motor drive control data from a control 
5 data table stored to memory 2 at the phase change timing, and sends the control 
data to motor drive controller 24. The motor drive controller 24 drives motor driver 
74 based on the control data, and thus causes motor 25 to turn. When the motor 25 
turns, carriage 73 moves side to side through the carriage path by way of a power 
transfer mechanism 71. Simultaneously to sending the control data, CPU 1 
10 computes the motor drive from the control data and determines from the computed 
motor drive the logical current position of carriage 73. A photosensor or other 
O detector 72 is disposed at the home position in the path of carriage 73 movement. 

m When the carriage 73 moves to the home position, detection circuit 75 detects the 

W carriage presence. When the detection circuit 75 detects that the carriage 73 is in 

n 15 the home position, it sends an interrupt signal (home position (HP) detection signal 
ly in this case) to the CPU 1. When CPU 1 receives this interrupt signal it compares 

the logical carriage position with the home position to determine whether the 
3 carriage 73 is being driven normally. If the computed position is greatly offset from 

J the carriage position at the home position, CPU 1 knows that carriage 73 drive is 

D 20 not normal and runs a particular error handling process. Motor drive control and 
position confirmation operations in the CPU 1 interrupt control process thus 
maintain accurate carriage movement. 

OBJECTS OF THE INVENTION 

However, there is a problem with the CPU interrupt control process as 
25 described above. In that process the CPU load is increased by reading control data 
from memory whenever drive control is needed. The CPU normally executes many 
different processes, and if overall CPU processing power is not sufficient for 
interrupt control and these other processes, the interrupt process time varies and it 
can be difficult to sustain fast, high precision drive control. To suppress fluctuation 
30 in the interrupt process and enable high precision motor control in such cases, it is 
necessary to accelerate the CPU or take other measures. This is also true when the 
drive error detection operation and process are run within the CPU interrupt 
process. 

The present invention therefore provides a drive mechanism control device 
35 that minimizes CPU interrupt processes after drive control starts, a corresponding 
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control method that can be easily changed as necessary, and a program for 
implementing this control method. 

The present invention further provides a drive control device arid control 
method capable of detecting drive errors and minimizing CPU interrupt processes 
5 after drive control starts. 

Another object of this invention is to provide a drive control drive for 
comparing a logical drive operation determined from the control data with the 
actual drive operation to confirm whether drive control is normal and enable precise 
drive control. 

10 SUMMARY OF THE INVENTION 

With consideration for and as a result of research into solutions for the 
IM aforementioned problems, the inventor has found that the above problems can be 

%I solved by using a direct memory access controller to read timing and control data 

y from memory and send the control data to a drive controller. 

15 With the present invention, drive timing data contained in a table for 

3 controlling drive timing and plural tables for recording control data used at each 

I control change timing for each of plural control data types are stored to memory 

I before the drive mechanism is driven. When the CPU issues a drive start request, 

the DMA reads the first timing data, which triggers reading the first control data 
20 and the next timing data. As a result, the DMA sequentially reads the control data 
type for each timing at which drive mechanism operation changes, and sends the 
necessary control data to the drive mechanism. Drive mechanism operation can 
thus be controlled independently of, and without any, CPU interrupts once 
operation starts. The change timing is controlled by setting the timing data to a 
25 timer. 

According to one aspect of the present invention, a drive mechanism control 
apparatus is provided. Such an apparatus comprises a driver; a drive controller in 
communication with the driver; a data generator for generating control data for 
controlling the driver, and for generating timing data for controlling output timing 

30 of the control data to the drive controller, wherein the drive controller controls 
operation of the driver based on the transmitted control data; a storage medium for 
storing the timing data and control data; a timer for starting a timing operation 
upon receipt of timing data, and for outputting a time-up signal when a time 
specified by the received timing data elapses; a first direct memory access for 

35 reading the timing data from the storage medium, and for sending the read timing 
data to the timer when activated by a specific signal; and a second direct memory 
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access for reading control data from the storage medium, and for sending the read 
control data to the drive controller when the time-up signal is received from the 
timer. 

The data generator can be configured to generate plural timing data and 
5 plural control data corresponding to the plural timing data; the second direct 
memory access is configured to output to the first direct memory access a start 
signal to cause the first direct memory access to start reading second timing data 
after the second direct memory access completes the sending of control data 
corresponding to the first timing data to the drive controller; and the first direct 
10 memory access is configured to read the second timing data from the storage 
medium and send the second timing data to the timer based on the start signal. . 

The second direct memory access may further comprise a first control unit, 
activated by the time-up signal from the timer, for reading, from among plural 
control data stored to the storage medium, first control data corresponding to the 

15 first timing data each time the time-up signal is received, and for sending the read 
first control data to the drive controller; and a second control unit, activated by 
completion of sending the first control data, for reading, from among the plural 
control data stored to the storage medium, second control data corresponding to the 
second timing data, for sending the read second control data to the drive controller, 

20 and then for outputting the start signal to the first direct memory access. 

The drive mechanism control apparatus may further comprise a stepping 
motor. In this case, the timing data comprises timing data for controlling a phase 
change timing of the motor, and the control data comprises phase pattern data that 
is set when the motor phase changes and phase current data for controlling current 
25 supplied to the motor when the motor phase changes. 

When a stepping motor is employed, the data generator preferably generates 
basic timing data, phase pattern data, and phase current data for use during motor 
acceleration, deceleration, and constant speed operation, and generates the timing 
data, first control data, and second control data based on the basic timing data. 

30 The drive mechanism control apparatus may further comprise a head drive, 

wherein the timing data and control data comprises data controlling head drive 
timing, drive trigger data for actually driving the head, and print data. 

In a drive mechanism control apparatus according to another aspect of the 
invention, there is a driver and a drive controller in communication with the driver. 
35 The drive mechanism control apparatus further comprises a data generator for 
generating control data for controlling the driver, and for generating timing data for 
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controlling output timing of the control data to the drive controller, wherein the 
drive controller controls operation of the driver based on the transmitted control 
data; a storage medium for storing the timing data and control data; a timer for 
starting a timing operation upon receipt of timing data, and for outputting a time- 
5 up signal when a time specified by the timing data elapses; a direct memory access 
for reading the timing data from the storage medium, and for sending the read 
timing data to the timer when activated by a specific signal, and then for sending 
control data from the storage medium to the drive controller based on the time-up 
signal output from the timer; a position detector for outputting a position detection 
10 signal when an operating part of the drive mechanism reaches a first reference 
position; and a drive confirmation unit for computing a logical operating position of 
Q the drive mechanism from the sent control data, for confirming drive mechanism 

]^ operating status by comparing the logical operating position with the actual 

Ijj operating position based on the position detection signal, and for outputting an 

15 operating error signal when a drive operation error is detected. 

The drive confirmation unit may comprise a comparison data storage unit in 
which specific count values are stored; a counter that is initialized when the 
3 operating part is at a second reference position and counts each time the time-up 

J signal is received; and a comparator for comparing the value of the counter with a 

[I 20 specific count value stored in the comparison data storage unit. In this 
'■f configuration, the operating status of the drive mechanism is confirmed according to 

the comparison result of the comparator when the position detection signal is 
received. 

The comparison data storage unit may comprise a first comparison data 
25 storage unit for storing an allowable lower limit of a specific count value for 
measuring movement of the operating part from the second reference position to the 
first reference position; and a second comparison data storage unit for storing an 
allowable upper limit of the specific count value for measuring movement of the 
operating part from the second reference position to the first reference position. 
30 With this arrangement, the drive confirmation unit outputs the operating error 
signal if the position detection signal is received when the value of the counter is 
less than or equal to the allowable lower limit or greater than or equal to the 
allowable upper limit. 

The drive confirmation unit can also output the operating error signal as an 
35 interrupt signal to the data generator, and the data generator performs an error 
handling process corresponding to the operating error based on the interrupt signal. 
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In addition, a stop drive signal for stopping drive mechanism operation can 
be output based on the operating error signal from the drive confirmation unit. 

The drive mechanism control apparatus may further comprise a stepping 
motor. In this case, the timing data includes data for activating the change timing 
5 for the stepping motor phase change, a phase pattern for each change timing, and a 
supply current value for each change timing. 

In addition to the stepping motor, the drive mechanism control apparatus 
may further comprise a carriage that is driven by the motor. 

The drive mechanism control apparatus may further comprise a carriage for 
10 an ink jet print head. In this case, the drive confirmation unit performs the drive 
confirmation process when the carriage is driven to accomplish an ink jet head 
cleaning operation. 

According to another aspect of the present invention, a drive mechanism 
111 control method is provided. Such a method comprises steps for (a) generating and 
y 15 storing plural types of control data for controlling a driver and plural timing data 
for sequentially transmitting the plural control data one at a time; (b) reading first 
timing data of the plural timing data; (c) starting a timing operation when the read 
'5 first timing data is received, and outputting a time-up signal when a time specified 

H by the first timing data elapses; (d) reading one control data type based on the time- 

20 up signal, and sending that control data type to a drive mechanism controller; (e) 
1^ reading next timing data of the plural timing data when the control data type read 

in step (d) is sent to the drive mechanism controller, and repeating steps (c) and (d) 
for next timing data, another control data type, and another time-up signal; and (f) 
repeating step (e) until all of the stored plural timing data has been read. 

25 Step (d) may comprise (dl) sequentially and individually reading each type of 

control data from a first control data type to a last control data type according to the 
corresponding time-up signal, and sending each read control data type to the 
controller. 

A stepping motor may be employed in the drive mechanism, in which case the 
30 plural timing data can comprise phase change timing data for changing the phase of 
the motor, and one type of control data comprises phase pattern data that is applied 
to the stepping motor at each phase change and phase current data for controlling 
current supplied to the motor when the motor phase changes. 

Alternatively, or in addition to, the stepping motor, the drive mechanism may 
35 comprise a head drive. In this case, the plural timing data can comprise head drive 
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timing data for controlling the timing of a head drive, and one type of control data 
comprises head drive trigger data and print data. 

According to another aspect of the invention, a drive operation confirmation 
method for a drive mechanism is provided. Such a method comprises steps for (a) 
5 generating and storing plural control data for accomplishing a specific confirmation 
drive process and plural timing data controlling the timing of transmission of the 
plural control data; (b) driving the drive mechanism by sequentially reading the 
plural timing data, and sequentially reading and transmitting the plural control 
data at specific timing intervals, based on the read timing data, to a drive 
10 mechanism controller; (c) calculating a drive amount of the drive mechanism based 
on the read and transmitted plural timing data and plural control data; (d) 
O calculating a difference between an actual operating position and a calculated 
^ operating position of an operating part of the drive mechanism, based on a position 
y determined from the calculated drive amount and a position determined from a 
m 15 position detection signal; and (e) outputting an operating error signal when the 
m difference between the calculated operating position and the actual operating 

^0 position is outside a specific range. 

Q Step (c) may comprise counting transmissions of control data sent at the 

specific timing intervals in step (b). 

20 Step (e) may comprise outputting a stop signal stopping drive mechanism 

y. operation when the difference between the calculated operating position and the 

actual operating position is outside the specific range. 

The plural timing data may comprise timing data for changing a stepping 
motor phase pattern and change timing control data for changing the current 
25 control data, and the plural control data comprises phase pattern data for each 
changing timing, and current control data supplied at each change timing. 

In further aspects of the present invention, a computer program and/or a 
machine -readable medium storing such a program for directing a machine to 
perform the steps of any of the methods described above. The storage medium 
30 storing such a computer program can be a compact disc, floppy disc, hard disk, 
magnetically recordable tape, or electromagnetic signal. 

Other objects and attainments together with a fuller understanding of the 
invention will become apparent and appreciated by referring to the following 
description and claims taken in conjunction with the accompanying drawings. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is functional block diagram showing the configuration of a drive control 
device to which the present invention is applied; 

Fig. 2 is a functional block diagram showing the configuration of a first 
preferred embodiment of the present invention; 

Fig. 3 is a functional block diagram showing in further detail the 
configuration of a first preferred embodiment of the present invention; 

Fig. 4 illustrates the data flow and data transmission procedure when the 
control device shown in Fig. 3 sends control data to the drive mechanism; 

Fig. 5 is a functional block diagram of a control device for controlling stepping 
motor drive according to a second preferred embodiment of the present invention; 

Fig. 6 is a graph showing the typical control of a motor for driving a stepping 

motor; 

Fig. 7 shows the state transitions of a continuous control operation loop from 
the start motor drive request to setting the change timing, first control data, and 
second control data, driving the motor, and setting the next change timing; 

Fig. 8 is a flow chart of the motor drive control process of the second 
embodiment of the invention; 

Fig. 9 is a functional block diagram showing a control device according to the 
present invention for controlling a print head; 

Fig. 10 shows the state transitions of a continuous control operation loop 
from the start head drive request to setting the change timing, first control data, 
and second control data, printing, and setting the next change timing; 

Fig. 11 is a functional block diagram showing the configuration of a drive 
mechanism control device according to a third embodiment of the invention where 
the drive mechanism is a carriage drive mechanism for moving the print head of a 
serial printer horizontally along the print line; 

Fig. 12 is a functional block diagram for describing in further detail the 
operation of the carriage drive mechanism control device shown in Fig. 11; 

Fig. 13 shows the locations of serial printer carriage movement range, 
printable area, no-printing area, and the home position; 

Fig. 14 is a state transition diagram showing various states in the drive 
confirmation process; 
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Fig. 15 shows an exemplary configuration of the drive confirmation unit of 
the present invention; 

Fig. 16 is a flow chart showing the confirmation operation of a controller of a 
drive confirmation unit; 

5 Fig. 17 is a state transition diagram showing the relationship between a 

continuous control operation from the start motor drive request to setting the 
change timing data, phase pattern data, and phase current data to setting the next 
change timing, and the drive confirmation process of this control operation; and 

Fig. 18 is a block diagram describing a conventional drive confirmation 
10 process using a CPU. 

Kev to the figures 
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DESCRIPTION OF THE PREFERRED EMBODIMENTS 

The preferred embodiments of the present invention are described below with 
reference to the accompanying figures. 

'5 10 Fig. 1 is a schematic block diagram of the configuration of a drive control 

I d device, including a drive mechanism, according to a first embodiment of the present 

IJI invention. The central processing unit 1 accomplishes various operations, processes, 

fn and control according to a program (including firmware and OS) stored in memory 

2. A direct memory access controller ("DMA" below) 3 enables data to be exchanged 
15 between memory 2 and other I/O devices without going through CPU 1. For ease of 
description, only timer 4 and drive mechanism 5 are shown in Fig. 1 as I/O devices. 
rT' However, it is to be understood that other I/O devices may be included. 

The memory 2 read address and send destination for the read data are 
specified by address line 8, and the read data is output via data bus 9. When timing 
20 data is sent from memory 2 to timer 4, the timer tracks time according to the 
received timing data, and outputs a time-up signal to the DMA 3 when the specified 
time elapses. The DMA 3 then sends the specified data from memory 2 to drive 
controller 6, and driver 7 of drive mechanism 5 operates according to the control 
data. 

25 A more detailed example of the drive control device is described next with 

reference to Fig. 2, which is a functional block diagram. Referring to Fig. 2, timing 
data storage 10 stores the data controlling the timing at which drive mechanism 
operation switches. A first control data storage 11 stores first control data for 
controlling drive mechanism operation after operation switches, second control data 

30 storage 12 stores second control data, and N-th control data storage 13 stores the N- 
th control data. Note that timing data storages 10 to 13 are preferably implemented 
as tables and are achieved by allocating a specific address space in memory. Specific 
data is stored to these storage tables by the CPU 1 before the start of the drive 
operation. 
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A first direct memory access (DMA) 14 and second DMA 15 are also provided. 
Note that first DMA 14 and second DMA 15 can be achieved in a single direct 
memory access unit, or using plural discrete DMA units. 

Timer 4 clocks time based on the timing data, and outputs a time-up signal. 
5 A drive controller 6 controls the driving of driver 7 based on received control data 
sent from the first controller 16 (see Fig. 3) and second controller 17 (see Fig. 3). 
The driver 7 is typically a stepping motor or print head, but is not so limited. 
Operation is described next. 

When a start driving signal is sent from CPU 1 to first DMA 14, first DMA 14 
10 reads first timing data from the table in timing data storage 10, and sends the 
timing data to timer 4. The timing data as used here specifies the time interval 
from the current operating state until operation is changed to a next operation. 
When the timing data is sent to timer 4, the timer starts counting the time 
indicated by the timing data and outputs a time-up signal to second DMA 15 when 
15 the specified time has elapsed. 

When this time-up signal is received, second DMA 15 first reads the control 
data stored first to first control data storage 11, and sends the control data to drive 
controller 6 of drive mechanism 5. When sending this first control data is completed, 
the control data stored first to second control data storage 12 is read and sent to 

20 drive controller 6. This operation continues to sequentially send the first control 
data stored to the N-th control data storage 13, which stores the N-th control data 
needed for drive control, to the drive controller 6. The drive controller 6 then 
controls driver operation based on the first to N-th control data (n control data) thus 
received. It should be noted that "N" is a desired number and differs according to 

25 the number of types of control data needed to control driving the particular drive 
mechanism, such as print head, carriage, or paper feed mechanism. 

When the last, that is, the N-th, control data is sent to drive controller 6, first 
DMA 14 is activated again by a particular trigger such as sending the N-th control 
data to drive controller 6. It should be noted that while the completion of control 
30 data transmission is preferably the trigger for again activating first DMA 14, 
another event relating to control data transmission (such as start of transmission) 
can be alternatively used. The trigger is assumed here to be the completion of 
control data transmission. 

As shown by solid line 27 in Fig. 2, first DMA 14 can be activated by an 
35 interrupt signal sent from second DMA 15 to first DMA 14 when sending the N-th 
control data ends. Alternatively, first DMA 14 can be activated by drive controller 6 
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sending an interrupt signal to the first DMA 14 as indicated by dotted line 28 in 
Fig. 2. 

When triggered by the activate signal from second DMA 15 or drive controller 
6, first DMA 14 reads the second timing data from timing data storage 10, and 
5 sends this timing data to timer 4. Timer 4 then clocks the time specified by the 
received timing data, and sends a next (second in this case) time-up signal to the 
second DMA 15 when the specified time passes. 

When this time-up signal is received, the second DMA 15 sequentially reads 
the control data stored second to the first to N-th control data tables, and sends the 
10 read control data to drive controller 6. 

The driver 7 is thereafter driven according to the timing data and control 
data stored to timing data table 10 to N-th control data table 13 until the specified 
JfJ drive operation is completed. It is thus possible to precisely and accurately control 

in drive mechanism operation without involving the CPU 1 once drive operation starts 

■rf 15 if the CPU 1 stores all timing data and control data needed for the particular drive 
?n mechanism as the control data (such as drive distance or speed) for driver 7 to 

;L, tables 10 to 13 before driving starts. 

F The second DMA 15 is described in further detail next. 

y It should be noted that while in Fig. 2 first to N-th control data tables (N 

J 20 types) is used as the control data other than the timing data for controlling drive 
mechanism operation, the types of control data actually used will vary according to 
the drive mechanism and drive mode. For example, two types of control data are 
typically used in addition to the timing data to control driving a stepping motor. 
Therefore, to simplify the present description, timing data and two types of control 
25 data are used by way of example only. 

Fig. 3 is a functional block diagram showing the configuration of an 
embodiment using timing data and two types of control data and illustrates a more 
detailed example of the second DMA 15. The second DMA 15 comprises a first 
controller 16 and a second controller 17 corresponding to the control data types. 
30 Note that the first and second controllers 16 and 17 are direct memory access 
controllers capable of reading data directly from memory without going through the 
CPU. 

When timing data is sent from first DMA 14 to timer 4 and timer 4 detects 
that the time specified by the timing data has passed, timer 4 sends a time-up 
35 signal to first controller 16. 
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When the time-up signal is received, first controller 16 reads the first control 
data fi:om the first control data table stored to first control data storage 11, and 
passes the read data to drive controller 6 of drive mechanism 5. When sending the 
first control data to drive controller 6 ends, second controller 17 is activated. Note 
5 that second controller 17 can be comprised to activate when first controller 16 sends 
an interrupt signal (indicated by solid line 26) to second controller 17 after sending 
the first control data ends, or to activate when drive controller 6 sends an interrupt 
signal (indicated by dotted line 29) to second controller 17 after receiving the first 
control data is completed. 

10 The second controller 17 reads the second control data first stored to second 

control data table 12, and sends it to drive controller 6, Based on this control data, 
p drive controller 6 starts operation of driver 7 when the first control data is received 

: or when both the first and second control data are received, 

W When sending the second control data to drive controller 6 ends, first DMA 14 

I si- 

p 15 is activated. Note that the first DMA 14 can be activated by sending an interrupt 
signal (solid line 27) from second controller 17 to first DMA 14 after sending the 
'T' second control data ends, or by sending an interrupt signal (dotted line 28) from 

P drive controller 6 to first DMA 14. 

1^ When first DMA 14 receives an interrupt signal from second controller 17 or 

Ji' 20 drive controller 6, it reads the next (second) timing data from the timing data table, 
i2 and sends it to timer 4. The timer 4 then clocks the time based on the received 

timing data, and when the specified time passes sends a next (second) time-up 

signal to first controller 16. 

As described above, the first controller 16 then reads the first control data 
25 from the first control data table, and sends it to the drive controller 6. When 
sending the first control data ends, the second controller 17 is again driven as 
described above to read the second control data from the second control data table 
and send the data to the drive controller 6. Operation of the driver 7 based on the 
previous control data stops at this point and operation based on the next control 
30 data starts. 

The above described operation continues so that driver 7 is driven based on 
the timing data and drive control data stored to timing data table 10, first control 
data table 11, and second control data table 12 until the specific drive operation 
ends. 

35 Fig. 4 shows the data .flow and data transmission procedure for sending 

timing data and control data to the drive mechanism 5. As noted above, timing data 
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table 10, first control data table 11, and second control data table 12 may each be a 
specific address space in memory 2, and first DMA 14, first controller 16, and 
second controller 17 may be embodied in DMA 3. 

Before drive mechanism operation starts, CPU 1 first writes the timing data, 
5 first control data, and second control data for controlling the drive mechanism 5 to 
be driven to specific addresses in memory 2. Operation then proceeds as described 
below to control the operation of drive mechanism 5. 

(I) CPU 1 sends a signal for activating first DMA 14 to DMA controller 18 of 
DMA 3. 

lb (2) DMA controller 18 thus activates first DMA 14. 

Q (3) As described above, first DMA 14 reads data from timing data table 10 of 

g memory 2. The address of the read data is stored to a source address register in first 

M DMA 14 and is incremented to specify the next data address after each read. 

|1{ (4) The read timing data is then sent to timer 4 based on the address specified in 

ru 15 send address register 20. 

Hi (5) The timer 4 monitors the passage of the time specified by the timing data, 

■~ and sends a time -up signal to first controller 16 when the indicated time is up. A 

^ typical timer can be used for timer 4. 

3 (6) When the time-up signal is received, first controller 16 reads the first control 

20 data by referencing its own source address register (not shown in the figure). The 
address stored to the source address register is then incremented to the next data 
address. 

(7) The read first control data is then sent to drive mechanism 5 based on the 
address in the send address register (not shown in the figure). 

25 (8) The second controller 17 is activated when sending the first control data 
ends. 

(9) The second controller 17 then read the second control data. As with first 
DMA 14 and first controller 16, the second controller 17 send address register (not 
shown in the figure) is then incremented to the next data address. 

30 (10) The read second control data is sent to drive mechanism 5. 

(II) When sending the second control data ends, first DMA 14 is activated again 
and reads the next timing data based on the incremented address data in send 
address register 19. 
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This same process repeats to control drive mechanism operation until driving 

ends. 

As a second embodiment of the present invention, an embodiment applying 
the principles of the first embodiment to a drive mechanism using a stepping motor 
5 as an example of a driver is described next below. However, this embodiment is 
exemplary only and is therefore not intended to so limit the invention. More 
broadly, the present invention can also be applied to drive mechanisms using a 
linear motor, drive mechanisms using ultrasonic oscillators, drive mechanisms 
using electromagnets, drive mechanisms using a combination of these, as well as all 
10 other types of drive mechanisms consistent with the technical concept of the 
invention. The drive mechanism control device and method of the present invention 
is therefore not limited to use with printers, but may also be applied to ATMs, card 
readers and scanners, and other types of drive mechanisms. 

The second preferred embodiment of the present invention is described next 
15 with reference to Fig. 5, which is functional block diagram of a control device 
according to the present invention for controlling the drive of a stepping motor. The 
first DMA 14, first controller 16, and second controller 17 in Fig. 3 are shown in Fig. 
5 as phase change timing controller 21, phase pattern controller 22, and phase 
current controller 23, respectively. Each of these controllers is a DMA, but the 
20 control functions of these components are shown as functional blocks for ease of 
understanding. These controllers 21 to 23 send specific control data to motor drive 
controller 24 to control the driving of stepping motor 25. 

Fig. 6 is a graph showing a typical example of motor control for driving 
stepping motor 25. Driving a stepping motor requires sequentially changing the 

25 phase of voltage applied to the motor. It is also necessary to gradually accelerate the 
motor from the start of motor operation as shown in Fig. 6(A) until motor speed 
reaches a constant speed, then maintain this speed, and finally decelerate the motor 
when the stop position is approached. The phase change timing therefore differs 
during acceleration, constant speed operation, and deceleration. Current control is 

30 also necessary during each of acceleration, constant speed operation, and 
deceleration. 

To start driving the motor, it is necessary to provide a high current supply to 
start and acceleration motor rotation (see Fig. 6(B)). Less current is needed to 
maintain constant speed operation, but a high current supply must be provided 
35 again during deceleration in order to brake the motor. It should be noted that as 
shown in Fig. 6(B) a very low current flow to the motor is maintained even after the 
motor stops. This is to quickly dissipate any residual excitation of the motor, and a 
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weak current flows to the motor in all phases after the motor stops (this is known as 
"rush current"). Therefore, after the motor reaches the stop position, the final 
control data including the rush current phase pattern (all phases), rush current, 
and rush current supply time is sent to the drive controller, and the motor drive 
5 operation ends after the rush current supply time passes. 

The numbers below the abscissa of each graph indicate the phase change 
timing. As shown in Fig. 6, the drive of stepping motor 25 starts from the second 
phase change timing. 

The timing data and other control data, including all control data needed to 
10 successively control stepping motor 25 operation from acceleration, constant speed 
operation, deceleration, to stopping according to the scheduled drive amount of the 
Qi driver is generated by the CPU 1 before motor drive starts, and is stored to tables 

10 to 12a in memory 2. 

I j This is described in further detail with reference to Fig. 7, which shows the 

p 15 state transitions of the continuous control loop starting from receiving the start 
motor drive request to setting the change timing data, phase pattern data, phase 
.f" current data, and then setting the next change timing data. 

? ' When the start of drive control by CPU 1 is indicated, first DMA 21 reads the 

first timing data in timing data table 10 defining the phase change timing, and 
:^ 20 sends this data to timer 4. The timer 4 monitors passage of the specific time based 
f;:^ on the received timing data (state 1: 40). 

When timer 4 detects passage of the specific time, first controller 22 reads the 
first phase pattern from first control data table 11a, and sets the phase pattern data 
in motor drive controller 24 (state 2: 41). ^ 

25 When sending the first phase pattern data ends, second controller 23 reads 

the first phase current value from second control data table 12a, and sets the first 
phase current to motor drive controller 24. Once the phase current is set drive of 
stepping motor 25 starts (state 3: 42). 

When sending the phase current ends, first DMA 21 is driven again, and 
30 reads and sends the next timing data from timing data table 10 to timer 4 (state 1: 
40). When timer 4 detects passage of the specific time, second DMA 15 sets the next 
phase pattern to drive controller 6 (state 2: 41), and then sets the phase current 
(state 3: 42). Drive based on this second phase pattern thus begins. 

As will be understood from the above description, the first timing data is the 
35 time for setting the first phase pattern and phase current. The stepping motor 25 
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operates at the first set phase pattern and phase current until the period specified 
by the second timing data passes and the phase pattern changes. The stepping 
motor 25 is then driven according to this next phase pattern and phase current data 
until the next change timing. 

5 The drive of stepping motor 25 thus starts rotating at the second timing point 

as indicated in Fig. 6(A), and motor drive is thereafter controlled according to the 
specified change timing data and control data. 

Fig. 8 is a flow chart describing this motor drive control process. 

When drive of stepping motor 25 is requested by a program, for example, 
10 CPU 1 computes the phase change timing data (time intervals in this example) 
^ required for control from the start to the stop of driver operation, and the phase 

0 pattern and phase current data set at each timing change, and stores this data to 

the tables 10 to 12a reserved at a specific address in memory 2 (SlOO). The CPU 1 
then sends a start motor drive signal to first DMA 21 (SlOl). 

15 In response to the start drive command from CPU 1, first DMA 21 reads the 

time data from the timing data table in memory 2 (S102), and sends it to timer 4 
(S103). The timer starts operating when the timing data is applied thereto, and 
continues in this state as long as the time-up signal is not received (S104 returns 
no). Timer 4 outputs a time-up signal to first controller 22 after the specified time 
20 passes, and when the time-up signal is received (S104 returns yes), first controller 
22 reads and sends the phase data and phase pattern from memory 2 to motor drive 
controller 24 (S105, S106). 

When the sending the phase data and pattern ends, second controller 23 
reads the phase current data from the phase current data table (S107), and reads 
25 and sends the timing data for setting the phase current to the motor drive controller 
24 from the timing data table to the timer 4. Phase current thus flows to stepping 
motor 25, and motor drive starts. 

If there is timing data for a next phase change (S109 returns yes), first DMA 
21 reads the next timing data from the phase change timing data table and passes 
30 it to timer 4 (S102, S103). This state continues until timer 4 detects that the time is 
up (while S104 returns no). In other words, phase current set by step S108 the first 
time through this control loop flows to the drive mechanism for the time set by the 
time data in step S103 (second pass) at the phase pattern set by step S106 (first 
pass). 

35 When timer 4 detects the time is up (S104 returns yes), the second phase 

pattern and phase current data are set to motor drive controller 24 (S105 to S108), 
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and current flows for the time controlled by the third time data according to these 
phase pattern and phase current values (S102 to S104). The same steps S102 to 
S109 thereafter repeat based on the timing data from the phase change timing data 
table. This process ends when there is no more timing data in the phase change 
5 timing data table. 

A third embodiment of the present invention is described next with reference 
to Fig. 9, which is a functional block diagram of a control device according to the 
present invention for controlling print head drive. The first DMA 14, first controller 
16, and second controller 17 in Fig. 3 are shown in Fig. 9 as drive timing controller 
10 30, head drive trigger controller 31, and print data controller 32, respectively. As in 
the case shown in Fig. 3, these controllers 30 to 32 is preferably a DMA, and DMA 
functions are shown in separate blocks for ease of understanding only. These 
,Q controllers 30 to 32 send specific control data to a head drive controller 33 to control 
;W the drive of print head 34. 

ml5 The basic operation is the same as described above with reference to the 

JJl second embodiment, but the processed control data differs. More specifically, the 
timing data is head drive timing data, and the control data comprises head drive 
L trigger data in data table lib and print data in data table 12b. This data is written 

,g to respective tables by the CPU before drive starts. 

20 The basic operation is described next with reference to Fig. 10. 

i2 The first DMA drive timing controller 30 first sets the drive timing data to 

timer 4 (state 1: 40a). When the timer 4 times out, head drive trigger controller 31 
sends a drive trigger to the head drive controller to drive the print head (state 2: 
41a), Note that nothing is printed at this time because no print data has been sent. 
25 Next, print data controller 32 sends, for example, one dot line of print data to head 
drive controller 33 (state 3: 42a). Note that the amount of print data sent is 
preferably the amount of data that can be printed in one head drive (printing) 
operation. The head drive controller 33 stores the received print data and prints it 
when the next drive trigger is received. 

30 It should be noted that, although the second and third embodiments have 

been described separately, it is to be understood that these embodiments can be 
combined and the motor drive control of the second embodiment used to drive a 
paper transport mechanism, the carriage mechanism, etc. in the printer. Note 
further that if the motor of the second embodiment is used for driving something 

35 other than the carriage mechanism, the second embodiment, this third embodiment 
and the following fourth embodiment could be combined in a single printer. 
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In an arrangement which combines the second and third embodiments, the 
drive controller 24 in Fig. 5 and the drive controller 33 in Fig. 9 can be made to 
operate in conjunction with each other, as may be required. It is thus possible to 
separately apply the present invention to a head drive control device and a motor 
5 drive control device, and synchronize the operation of these two devices. Operation 
can be synchronized by, for example, synchronizing the control data for the motor 
drive mechanism and the head drive mechanism when the control data is 
generated, and storing the synchronized control data to memory so that actual drive 
is controlled based on the already- synchronized control data. Other methods could 
10 also be used, including synchronizing motor drive timing to the actual head drive 
timing, or otherwise synchronizing the timing to actual operation. 

It will also be noted that, in the configuration described above, next timing 
Q and control data is read and output after sending the previous timing and control 
^ data is completed. It is also possible to simultaneously send timing data and control 
iyi5 data depending on the properties of the particular driver. 

p A fourth embodiment of a drive control device according to the present 

J 2 invention is described next with reference to Fig. 11, which is a schematic block 
diagram of this embodiment. The drive mechanism in this embodiment is a carriage 
drive mechanism for moving the print head of a serial printer horizontally along a 
=^^20 print line. 

Q The carriage drive mechanism 70 comprises a motor drive controller 24, a 

H motor driver 74, and a stepping motor 25 for driving a carriage 73 via a power 
transfer mechanism 71 (comprising a toothed belt, gears, or other functionally 
equivalent structure). Carriage position and movement are precisely controlled by 
25 precisely changing the phases of stepping motor 25. 

As in the first embodiment above, CPU 1 is a central processing unit that 
accomplishes various operations, processes, and control according to a program 
(including firmware and OS) stored in memory 2. Direct memory access controller 3 
enables data to be exchanged between memory 2 and other I/O devices without 
30 going through CPU 1. 

Firmware and an operating system (OS) for controlling CPU operation, other 
various programs, and control data needed to control carriage drive mechanism 70 
are stored to memory 2. The memory 2 read address and send destination for the 
read data are specified by address line 8, and the read data is output via data bus 9. 

35 When timing data is sent from memory 2 to timer 4, timer 4 tracks time 

according to the received timing data, and outputs a time-up signal to the DMA 3 
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when the specified time elapses. DMA 3 then sends specific data fi:om memory 2 to 
motor drive controller 24 of carriage drive mechanism 70. The motor controller 
drives the motor driver 74 according to this control data, and the stepping motor 25 
turns. When the stepping motor 25 turns, carriage 73 is moved along the print Une 
5 in the carriage track by power transfer mechanism 71 (comprising a toothed belt, 
gears, or other functionally equivalent structure). 

A home position sensor 72 is disposed in the carriage path at the home 
position (HP) of the carriage movement range. This HP detector 72 can be a 
photodetector, ultrasonic detector, mechanical sensor, or other sensing element. 

10 The output signal from the HP detector 72 is applied to a drive confirmation 

unit 50, which sequentially tracks the computed carriage 73 position and detects 
the offset between the actual carriage position and the computed carriage position 
from the computed carriage 73 position when the HP detector 72 detects the 
f% carriage. If the offset is greater than a specified range, an interrupt signal is sent to 
ij|15 the CPU. When the CPU detects an interrupt signal from the drive confirmation 
Jff unit 50, it runs a specific error handling process. 

^0 The embodiment shown in Fig. 11 is described in further detail next with 

1^ reference to Fig. 12, which is a functional block diagram describing the operation of 
the carriage drive mechanism controller in greater detail. Note that control data 
tables 10 to 12a are contained in memory 2. The control data stored to these tables 
G is the data needed to control motor drive according to the movement of the carriage 
to be driven. The control data is generated according to a motor drive control 
program stored to memory 2 before the motor drive operation starts. 

Referring to Fig. 12, timing data table 10 stores the data controlling the 
25 timing at which motor operation switches. Phase pattern data table 11a stores the 
phase pattern data of the voltage supplied to the motor at each change of operation, 
and phase current table 12a stores the phase current data controlling phase current 
flow to the motor at each change of operation. It should be noted that Fig. 12 shows 
two types of control data being stored, but more or less types of control data can be 
30 stored as may be needed. Furthermore, this data can be stored in a register or other 
storage medium (not shown in the figure) rather than in memory 2. 

Data tables 10 to 12a in memory 2 are read respectively by phase change 
timing controller 21, phase pattern controller 22, and phase current controller 23 of 
DMA 3, and the read data is passed thereby to other specific parts. Controllers 21 to 
35 23 are DMA devices, and sequentially send the control data read from controllers 21 
to 23. The first send operation of the DMA is activated by a start operation signal 
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from CPU 1. Thereafter, controllers (DMA) 21 to 23 are sequentially made active to 
read and send the respective data signals by means of a time-up signal or the end of 
each send operation. 

Timing data is first sent by phase change timing controller 21 from timing 
5 data table 10 to timer 4. After the period indicated by the timing data passes, timer 
4 outputs a time-up signal to phase pattern controller 22 and drive confirmation 
unit 50. When the time-up signal is received, phase pattern controller 22 reads and 
sends the phase pattern data to motor drive controller 24 from first control data 
table 11a, The motor drive controller 24 outputs the received phase pattern data to 

10 motor driver 74. Next, phase current controller 23 reads the phase current value 
from second control data table 12a and sends it to motor drive controller 24. The 
motor drive controller 24 outputs the received phase current value to motor driver 
74, and the stepping motor 25 then starts turning. When the stepping motor 25 
starts turning, power transfer mechanism 71 causes carriage 73 to begin traveling 

15 through the carriage path. 

When sending the phase current data ends, phase current controller 23 
passes control to phase change timing controller 21. The phase change timing 
controller 21 thus reads the next timing data and sends it to timer 4. The timer 4 
outputs a time-up signal when the specified time passes, making phase pattern 
20 controller 22 active to send the next phase pattern. The same process thereafter 
continues so that stepping motor 25 gradually accelerates and drives movement of 
carriage 73. 

The carriage path is described next with reference to Fig. 13, which shows 
the carriage movement range 81, printable area 82, no-printing area 83, and home 

25 position (HP) locations of a typical serial printer. The greatest part of the carriage 
movement range is printable area 82. Printing is accomplished by the print head 
(not shown in the figure) as the carriage 73 travels through the printable area 82. 
The printable area 82 differs according to the type of printer, for example, and for 
simplicity only one printable area 82 is shown in Fig. 13. A specific area from the 

30 right end is no-printing area 83. The carriage 73 can travel through the no-printing 
area 83, but printing is prohibited. 

A home position detector 72 (see Figs. 11 and 12), which is equivalent to a 
location sensor, is disposed to a particular position (e.g., a first reference position) 
known as the home position (HP) in the no-printing area 83. When the carriage 73 
35 moves across the home position sensor, the home position sensor detects the 
carriage 73 and thus makes it possible to confirm if the carriage 73 has actually 
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moved to the home position. The HP detector 72 outputs a detection signal to the 
drive confirmation unit 50 when it detects the carriage. 

The carriage 73 is moved by driving the stepping motor 25. To print to an 
area containing one continuous Une, for example, carriage 73 moves from the right 
5 end of the printable area 82 to the left end of the printable area. When printing is 
completed, the carriage 73 can be designed to stop at that position, return to the 
right end of the printable area, or move to some other desired position. 

As noted above, moving carriage 73 to print is accomplished by generating 
and storing to memory the motor control data required to a specific movement, the 
10 stored control data is then read by a DMA device and sent to the drive controller. 
Generating and storing the motor control data to memory can be accomplished by 
^ means of a CPU and specific program. 

As is the case for printing, a carriage drive operation for confirming whether 
iVj the carriage drive operation is correctly accomplished ("drive state confirmation" 
^£^5 below) is also achieved by generating and storing motor control data to memory in 
advance of carriage drive, and then sequentially reading and sending this data by 
means of a DMA device to the drive controller. This drive state confirmation 
operation is preferably performed at a regular specific interval in order to achieve 
M precise drive control. 

ry20 In the case of an ink jet printer, for example, a dummy ink ejection operation 

is performed regularly when not printing in order to prevent the print head from 
drying when there is a long interval between printing operations. The carriage is 
therefore moved regularly (every 6 to 10 seconds, for example) to an ink receptor 
position for receiving the ejected ink. The ink receptor is therefore normally 
25 disposed near the home position in the no-printing area 83. The drive confirmation 
process can therefore be structured to run simultaneously with the ink ejection 
operation. It should be noted that while the carriage 73 drive operation is the same 
for both processes, the drive state confirmation process must be performed parallel 
to print head drive control for ink ejection. 

30 An example of the drive state confirmation process is described next with 

reference to Fig. 14, which is a state transition diagram for describing this drive 
state confirmation process. 

Typical carriage movement in conjunction with drive state confirmation is 
described briefly before describing the process in Fig. 14. 

35 The carriage is first stopped at a second reference position (S in Fig. 13) in 

the standby mode. Control and timing data for the drive state confirmation 

PatApplAF Express Mail Label No. EL700475853US 

Customer No. 20178 Rev. 11/97 



P5740a 

operation is generated in this state and stored to memory. When the CPU then 
outputs a start drive signal to the DMA, the DMA reads the control data from 
memory and sends it to the timer and drive controller, respectively. Drive control of 
stepping motor 25 thus starts. When the motor is driven, carriage 73 moves 
5 gradually to the right from the second reference position S. When the carriage 
passes the home position, the home position sensor outputs a detection signal. The 
drive state is confirmed based on the detection signal from the home position 
sensor. 

The drive state confirmation process is described next. All flags and counters, 
10 etc. are cleared in standby state 51, that is, when the drive state confirmation 

process is not running. To start the drive state confirmation process, CPU 1 

generates timing data and control data in order to move the carriage 73 to the home 
O position HP for the drive state confirmation process, and stores this data to tables 

10 to 12a in memory 2. After this control data is stored to memory, CPU 1 activates 
till 5 phase change timing controller 21 of DMA 3 (see Fig. 12), and starts drive control of 
Zl stepping motor 25 to move the carriage. The signal starting drive control 
m simultaneously starts the drive state confirmation process and enters the lower 

limit standby state 52 shown in Fig. 14. 

^3 Whether the computed logical position of the carriage 73 has reached a 

220 computed lower limit allowed for the home position is checked in this lower limit 
lU standby state 52. If the HP detection signal is detected before the logical position of 
the carriage 73 reaches the lower limit, the actual carriage position is known to be 
to offset greatly to the right (as seen in Fig. 13) from the logical carriage position, 
and a drive error is determined to have occurred. Whether the home position HP is 
25 detected before the lower limit is reached is therefore determined (HP detection 1). 
A drive error is detected if the home position is detected before the carriage position 
reaches the lower limit position, and an interrupt signal is output to the CPU 1 for 
an error handling process (error handling process output INT state 54). If the home 
position is not detected in HP detection 1, lower limit standby state 52 continues. 

30 If the lower limit position is reached with no HP detection signal having been 

detected, an upper limit standby state 53 is assumed. Whether the logical position 
of the carriage 73 has reached a computed upper limit position allowed for the home 
position is checked in this upper limit standby state 53. If the HP detection signal is 
not detected by the time the logical position of the carriage 73 reaches the upper 

35 limit, the actual carriage position is known to be to offset greatly to the left (as seen 
in Fig. 13) from the logical carriage position, and a drive error is determined to have 
occurred. 
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To detect this state, it is confirmed whether the home position is detected at 
each phase change time until the upper Umit position is reached (HP detection 2). If 
the home position is not detected by the time the upper hmit position is reached, an 
interrupt signal is output to the CPU 1 to activate the CPU 1 and run a specific 
5 error handling process (state 54). If an error interrupt is applied to the CPU 1, the 
CPU 1 indicates a drive error, runs an appropriate error handling process, and 
waits for recovery from the error (state 56). 

If the home position is detected in HP detection state 2, the offset between 
the logical carriage position and the actual carriage position is known to be within 
10 an acceptable range, and a normal termination process 55 is run to normally 
terminate the drive state confirmation process. This normal termination process 55 
can, for example, drive the carriage to the right end of the printing area 82 after 
home position HP detection and re-enable printing (state 56). 

J^^^ Fig. 15 is a functional block diagram of an exemplary drive confirmation unit 

Ijil5 50 according to the present invention. The drive confirmation unit 50 has a lower 
O limit register 61 for storing the allowable lower limit position computed as the home 
position HP, and an upper limit register drive 65 for storing a computed allowable 
upper limit position. The lower and upper limit position values are stored to lower 
limit register 61 and upper limit register 65, respectively, by CPU 1 via data bus 9. 
|f-^20 The drive confirmation unit 50 also comprises a counter 63, which counts up 
:^ according to the phase change signal (time-up signal). The counter 63 is cleared by a 

signal from controller 60 before starting the drive state confirmation process. The 
incremented count of counter 63 is compared by comparators 62 and 64 with the 
values from lower limit register 61 and upper limit register 65, respectively. If the 
25 counter 63 value matches the value stored to lower limit register 61 or upper limit 
register 65, a match signal is output to the controller 60. 

The controller 60 operates according to data stored in control register 66, and 
after the drive state confirmation process has been executed its state (the result) is 
stored to state register 67. Data from CPU 1 is written to control register 66, and 
30 CPU 1 can read from state register 67. CPU 1 can also read the current count from 
counter 63 via data bus 9. The match signal, phase change signal (time-up signal), 
home position signal HP, and others are input to controller 60, which detects drive 
errors based on the match signal output timing from comparator 64 and the timing 
at which home position signal HP is received. 

35 The operation of controller 60 is described next with reference to Figs. 13, 15 

and 16, the latter of which is a flow chart showing the drive state confirmation 
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process of the controller 60 of drive confirmation unit 50. Assume that carriage 73 is 
initially stopped at position S in Fig. 13. 

Before starting the drive state confirmation process, CPU 1 sets the motor 
drive control data to memory 2 as described above. At the same time CPU 1 also 
clears lower limit register 61, upper limit register 65, control register 66, and 
counter 63. The values set to upper limit register 65 and lower limit register 61 can 
be freely determined according to the desired degree of error detection precision. In 
this example the lower limit position is set to "1000" in lower limit register 61, and 
the upper limit position is set to "1020" in upper limit register 65. 

When CPU 1 activates phase change timing controller 21 in DMA 3, it also 
activates drive confirmation unit 50 at the same time (S200). Based on timer data 
from phase change timing controller 21 (see Fig. 12), timer 4 outputs a time-up 
signal at each phase change timing. Based on the time-up signal, phase pattern 
controller 22 and phase current controller 23 send the phase pattern and phase 
current data to motor drive controller 24. The motor drive controller 24 then drives 
stepping motor 25 based on this control data, and carriage 73 begins moving toward 
home position. 

Once drive confirmation unit 50 starts the drive state confirmation process, 
counter 63 increments each time timer 4 outputs the time-up signal (S201, S202). 
Whether HP detector 72 outputs a detection signal is then checked. If the HP 
detection signal is not output (S203 returns no), the values from counter 63 and 
lower limit register 61 are compared (S204). If the value of counter 63 has not 
reached the lower limit value (S204 returns no), the same process repeats (that is, 
steps S201, S202, S203, and S204). 

Note that detection of the HP detection signal in S203 means that the 
carriage 73 has actually reached the home position even though the computed 
position of carriage 73 has not reached the lower limit setting of 1000. An error is 
therefore detected (S203 returns yes) and an interrupt signal is output to CPU 1 
(S209). The registers 61, 65 are then cleared (S211) and a standby state assumed 
(S200). Note that the CPU 1 can reference the content of counter 63 and state 
register 67 by means of an interrupt error handling process. 

When counter 63 increments to 1000, the value in lower limit register 61 and 
the counter 63 value match (S204 returns yes). The upper limit standby state 53 
(see Fig. 14) is therefore assumed and the next time-up signal is awaited (S205 
returns no). When a time-up signal is received (S205 returns yes), counter 63 
increments (S206), and whether the HP detection signal is output is checked (S207). 
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If the HP detection signal is not output (S207 returns no), the value in upper limit 
register 65 is compared with the counter 63 value (S208). If they are not the same 
(S208 returns no), the same process steps are repeated (that is, S205, S206, S207, 
S208). If the HP detection signal is detected (S207 returns yes), carriage 73 has 
5 reached the actual home position within the range: lower limit 1000 < counter 
value < upper limit 1020. The logical and actual carriage 73 positions are thus 
within a specific tolerance range, drive is determined to be normal, counter 63 and 
register 65 are cleared (S210), and standby state 51 (see Fig. 14) is assumed. If the 
counter reaches 1020, the value set to upper limit register 65 and the counter 63 
10 match (S208 returns yes). This means that even though the carriage should have 
moved to the logical upper limit position 1020, it has not actually reached the home 
position. A drive error is therefore detected. 

O If an error is determined after the home position is detected, an interrupt can 

be issued to the CPU 1, which then stops driving stepping motor 25, or stepping 
ml5 motor 25 can be driven to a specific position to enable error recovery. To terminate 
the process normally, the timing and control data generated and stored to memory 2 
m for the drive state confirmation process can include control data for returning the 
W carriage to a specific position (such as the second reference position S in Fig. 13) if 
o the step count (identical to the count tracked by counter 63) exceeds the upper limit 
;C20 1020 or 1021. 

fu The relationship between drive control of carriage 73 (drive control of 

Tl stepping motor 25) and the drive confirmation unit is described next with reference 
to Figs. 17 and 12. 

Fig. 17 shows the state transitions of the continuous control loop starting 
25 from receiving the start motor drive request to setting the change timing data, 
phase pattern data, phase current data, and then setting the next change timing 
data, and the relationship of the drive state confirmation process to this operation. 

When the start of drive control for the drive state confirmation process is 
indicated by CPU 1, the first timing data in timing data table 10 is read and sent to 
30 timer 4. The timer 4 monitors passage of the specific time interval based on the 
received timing data (state 1: 57). 

When timer 4 detects passage of the specific time, it outputs a time-up signal. 
Based thereon, phase pattern controller 22 reads the first phase pattern data from 
phase pattern data table 11a, and sets the phase to motor drive controller 24 (state 
35 2: 58). Drive confirmation unit 50 also increments counter 63 of drive confirmation 
unit 50 at the same time based on the time-up signal. 
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When sending the first phase pattern data ends, phase current controller 23 
reads the first phase current data from phase current table 12a, and sets the phase 
current to motor drive controller 24. Stepping motor 25 drive starts when this is 
completed (state 3: 59). 

5 When sending the phase current ends, phase change timing controller 21 is 

driven again to read and send the next timing data from phase change timing 
controller 21 to timer 4 (state 1: 57). Motor 25 based on the first phase pattern and 
phase current then proceeds until the timer 4 outputs a time-up signal based on the 
second timing data. 

10 When timer 4 detects the specific time has passed, it outputs a time-up 

signal. Based thereon, phase pattern controller 22 reads the next (second) phase 
pattern data and sets the phase of motor drive controller 24 (state 2: 58). Drive 

O 

ijj confirmation unit 50 also increments counter 63 at the same time based on the 
time-up signal. The next (second) phase current is then set by phase current 
m 15 controller 23 (state 3: 59). The stepping motor 25 is thus driven based on the second 
O phase pattern and phase current until the next (third) time-up signal is output. 

As will be understood from the above, the first timing data is a dummy value 
JU for setting the first phase pattern and phase current. The stepping motor 25 is 

=C driven at the first set phase pattern and phase current until the time specified by 

^ 20 the second timing data (time data) passes and the phase pattern changes. Likewise, 
O the stepping motor 25 is next driven until the next phase change timing according 

to the next phase pattern and phase current settings. 

The drive of motor 25 thus starts from the second phase change timing as 
shown in Fig. 6(A), and motor drive is controlled according to specific change timing 
25 data and control data. During this time the counter 63 of drive confirmation unit 50 
is incremented each time the time -up signal is output, and the counter is compared 
with lower limit register 61 and upper limit register 65. 

It should be noted that the above described drive confirmation operation is 
controlled by a program stored in memory. In a printer, for example, a home 

30 position sensor is normally disposed at a location separated from the printing area, 
and the carriage is driven so that it is detected by the home position sensor at least 
once every unit time to confirm carriage operation. The frequency of this drive state 
confirmation process can be freely determined by the designer when writing the 
drive control program. For example, by regularly performing this operation at a 

35 specific interval, the timing of the confirmation process can also be changed 
according to actual drive mechanism operation. 
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Furthermore, when the first reference position is set to a home position 
removed from the printing area, an error can be immediately detected if the home 
position is detected while printing is in progress. However, it will also be obvious 
that the first reference position is not necessarily set outside the printing area. A 
5 first reference position can be set inside the printing area with a sensor disposed 
thereto so that the drive state confirmation process can be accomplished while 
printing. 

Moreover, plural position sensors can also be provided. For example, the 
position sensors could be disposed on both sides of the path of movement, more than 
10 one could be disposed in the printing area, or sensors could be disposed both on the 
sides of the path of movement and in the printing area. Providing plural position 
sensors enables even more detailed, precise confirmation of drive control, and can 
Q further improve reliability. 

W Furthermore, a dummy ink ejection operation is performed at a regular 

r^l5 frequency in an ink jet printer to ensure normal printing. Therefore, by disposing a 
Q receptacle for the ink ejected by this dummy operation near the home position, 

5*5 

!S carriage drive for the dummy ink ejection operation can also be used for the drive 
state confirmation process. 

£ It should be noted that the above drive state confirmation process is 

20 described with reference to a print head carriage drive mechanism for a printer, but 
rj the invention is not so limited. For example, the concept of the present invention 

can be applied to virtually any field requiring precision drive mechanism control, 
including a printing paper transport mechanism, currency transport mechanism in 
an ATM, and a magnetic head or other type of head drive mechanism. It will be 
25 apparent that the location of the first and second reference positions will be 
appropriately determined based on knowledge and practice in the applicable field. 

Moreover, the preceding embodiments have been described with reference to 
a stepping motor drive mechanism and print head drive mechanism. As noted 
above, however, the invention is not so limited, since the invention can also be 

30 applied to drive mechanisms using a linear motor, drive mechanisms using 
ultrasonic oscillators, drive mechanisms using electromagnets, drive mechanisms 
using a combination of these, and all other types of drive mechanisms to which the 
technical concept of the invention can be applied. Furthermore, control data specific 
to these drive mechanisms can be supplied at timing specific to the drive 

35 mechanism using the DMA control of the present invention so that once driving 
starts drive mechanism control can continue without involving the CPU. 
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As described above, timing data and specific control data is stored to memory 
in advance of drive mechanism control in the present invention, and DMA is used to 
set the timing data to a timer and the control data to the drive mechanism. As a 
result, the present invention enables high precision control of motor drive without 
using CPU interrupts and without using expensive dedicated hardware. 

While the invention has been described in conjunction with several specific 
embodiments, further alternatives, modifications, variations and applications will 
be apparent to those skilled in the art that in light of the foregoing description. 
Thus, the invention described herein is intended to embrace all such alternatives, 
modifications, variations and applications as may fall within the spirit and scope of 
the appended claims. 
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